/*
 * @lc app=leetcode.cn id=160 lang=javascript
 *
 * [160] 相交链表
 */

// @lc code=start
/**
 * Definition for singly-linked list.
 * function ListNode(val) {
 *     this.val = val;
 *     this.next = null;
 * }
 */

/**
 * @param {ListNode} headA
 * @param {ListNode} headB
 * @return {ListNode}
 */
var getIntersectionNode = function(headA, headB) {
   if(!headA||!headB) return null
   let p1 = headA , p2 = headB
   while(p1!=p2){
       p1 = p1==null? headB : p1.next //当B链表遍历完后，再去遍历A链表，最坏的情况A和B都遍历一遍都没有相等同时为null跳出循环
       p2 = p2==null? headA : p2.next
   }
   return p1
};
// @lc code=end

